home *** CD-ROM | disk | FTP | other *** search
/ AmigActive 10 / AACD 10.iso / AACD / Games / MAME / src / drivers / cninja.c < prev    next >
C/C++ Source or Header  |  2000-04-23  |  42KB  |  1,229 lines

  1. /***************************************************************************
  2.  
  3.   Edward Randy      (c) 1990 Data East Corporation (World version)
  4.   Edward Randy      (c) 1990 Data East Corporation (Japanese version)
  5.   Caveman Ninja     (c) 1991 Data East Corporation (World version)
  6.   Caveman Ninja     (c) 1991 Data East Corporation (USA version)
  7.   Joe & Mac         (c) 1991 Data East Corporation (Japanese version)
  8.   Stone Age         (Italian bootleg)
  9.  
  10.   Edward Randy runs on the same board as Caveman Ninja but one custom chip
  11.   is different.  The chip controls protection and also seems to affect the
  12.   memory map.
  13.  
  14.  
  15. Sound (Original):
  16.   Hu6280 CPU
  17.   YM2151 (music)
  18.   YM2203C (effects)
  19.   2 Oki ADPCM chips
  20.  
  21. Sound (Bootleg):
  22.   Z80 (Program ripped from Block Out!)
  23.   YM2151
  24.   Oki chip
  25.  
  26. Caveman Ninja Issues:
  27.   End of level 2 is corrupt.
  28.  
  29.   Emulation by Bryan McPhail, mish@tendril.co.uk
  30.  
  31. ***************************************************************************/
  32.  
  33. #include "driver.h"
  34. #include "vidhrdw/generic.h"
  35. #include "cpu/h6280/h6280.h"
  36. #include "cpu/z80/z80.h"
  37.  
  38. /* Video emulation definitions */
  39. extern unsigned char *cninja_pf1_rowscroll,*cninja_pf2_rowscroll;
  40. extern unsigned char *cninja_pf3_rowscroll,*cninja_pf4_rowscroll;
  41. extern unsigned char *cninja_pf1_data,*cninja_pf2_data;
  42. extern unsigned char *cninja_pf3_data,*cninja_pf4_data;
  43.  
  44. int  cninja_vh_start(void);
  45. int  edrandy_vh_start(void);
  46. int  stoneage_vh_start(void);
  47. void cninja_vh_screenrefresh(struct osd_bitmap *bitmap,int full_refresh);
  48.  
  49. READ_HANDLER( cninja_pf3_rowscroll_r );
  50. READ_HANDLER( cninja_pf1_data_r );
  51.  
  52. WRITE_HANDLER( cninja_pf1_data_w );
  53. WRITE_HANDLER( cninja_pf2_data_w );
  54. WRITE_HANDLER( cninja_pf3_data_w );
  55. WRITE_HANDLER( cninja_pf4_data_w );
  56. WRITE_HANDLER( cninja_control_0_w );
  57. WRITE_HANDLER( cninja_control_1_w );
  58.  
  59. WRITE_HANDLER( cninja_pf1_rowscroll_w );
  60. WRITE_HANDLER( cninja_pf2_rowscroll_w );
  61. WRITE_HANDLER( cninja_pf3_rowscroll_w );
  62. WRITE_HANDLER( cninja_pf4_rowscroll_w );
  63.  
  64. WRITE_HANDLER( cninja_palette_24bit_w );
  65.  
  66. static int loopback[0x100];
  67. static unsigned char *cninja_ram;
  68.  
  69. /**********************************************************************************/
  70.  
  71. static WRITE_HANDLER( cninja_sound_w )
  72. {
  73.     soundlatch_w(0,data&0xff);
  74.     cpu_cause_interrupt(1,H6280_INT_IRQ1);
  75. }
  76.  
  77. static WRITE_HANDLER( stoneage_sound_w )
  78. {
  79.     soundlatch_w(0,data&0xff);
  80.     cpu_cause_interrupt(1,Z80_NMI_INT);
  81. }
  82.  
  83. static WRITE_HANDLER( cninja_loopback_w )
  84. {
  85.     COMBINE_WORD_MEM(&loopback[offset],data);
  86. #if 0
  87.     if ((offset>0x22 || offset<0x8) && (offset>0x94 || offset<0x80)
  88. && offset!=0x36 && offset!=0x9e && offset!=0x76 && offset!=0x58 && offset!=0x56
  89. && offset!=0x2c && offset!=0x34
  90. && (offset>0xb0 || offset<0xa0) /* in game prot writes */
  91. )
  92. logerror("Protection PC %06x: warning - write %04x to %04x\n",cpu_get_pc(),data,offset);
  93. #endif
  94. }
  95.  
  96. static READ_HANDLER( cninja_prot_r )
  97. {
  98.      switch (offset) {
  99.         case 0x80: /* Master level control */
  100.             return READ_WORD(&loopback[0]);
  101.  
  102.         case 0xde: /* Restart position control */
  103.             return READ_WORD(&loopback[2]);
  104.  
  105.         case 0xe6: /* The number of credits in the system. */
  106.             return READ_WORD(&loopback[4]);
  107.  
  108.         case 0x86: /* End of game check.  See 0x1814 */
  109.             return READ_WORD(&loopback[6]);
  110.  
  111.         /* Video registers */
  112.         case 0x5a: /* Moved to 0x140000 on int */
  113.             return READ_WORD(&loopback[0x10]);
  114.         case 0x84: /* Moved to 0x14000a on int */
  115.             return READ_WORD(&loopback[0x12]);
  116.         case 0x20: /* Moved to 0x14000c on int */
  117.             return READ_WORD(&loopback[0x14]);
  118.         case 0x72: /* Moved to 0x14000e on int */
  119.             return READ_WORD(&loopback[0x16]);
  120.         case 0xdc: /* Moved to 0x150000 on int */
  121.             return READ_WORD(&loopback[0x18]);
  122.         case 0x6e: /* Moved to 0x15000a on int */
  123.             return READ_WORD(&loopback[0x1a]); /* Not used on bootleg */
  124.         case 0x6c: /* Moved to 0x15000c on int */
  125.             return READ_WORD(&loopback[0x1c]);
  126.         case 0x08: /* Moved to 0x15000e on int */
  127.             return READ_WORD(&loopback[0x1e]);
  128.  
  129.         case 0x36: /* Dip switches */
  130.             return (readinputport(3) + (readinputport(4) << 8));
  131.  
  132.         case 0x1c8: /* Coins */
  133.             return readinputport(2);
  134.  
  135.         case 0x22c: /* Player 1 & 2 input ports */
  136.             return (readinputport(0) + (readinputport(1) << 8));
  137.     }
  138.     logerror("Protection PC %06x: warning - read unmapped memory address %04x\n",cpu_get_pc(),offset);
  139.     return 0;
  140. }
  141.  
  142. static READ_HANDLER( edrandy_prot_r )
  143. {
  144.      switch (offset) {
  145.         /* Video registers */
  146.         case 0x32a: /* Moved to 0x140006 on int */
  147.             return READ_WORD(&loopback[0x80]);
  148.         case 0x380: /* Moved to 0x140008 on int */
  149.             return READ_WORD(&loopback[0x84]);
  150.         case 0x63a: /* Moved to 0x150002 on int */
  151.             return READ_WORD(&loopback[0x88]);
  152.         case 0x42a: /* Moved to 0x150004 on int */
  153.             return READ_WORD(&loopback[0x8c]);
  154.         case 0x030: /* Moved to 0x150006 on int */
  155.             return READ_WORD(&loopback[0x90]);
  156.         case 0x6b2: /* Moved to 0x150008 on int */
  157.             return READ_WORD(&loopback[0x94]);
  158.  
  159.  
  160.  
  161.  
  162. case 0x6c4: /* dma enable, bit 7 set, below bit 5 */
  163. case 0x33e: return READ_WORD(&loopback[0x2c]); /* allows video registers */
  164.  
  165.  
  166.  
  167.  
  168.         /* memcpy selectors, transfer occurs in interrupt */
  169.         case 0x32e: return READ_WORD(&loopback[0x8]); /* src msb */
  170.         case 0x6d8: return READ_WORD(&loopback[0xa]); /* src lsb */
  171.         case 0x010: return READ_WORD(&loopback[0xc]); /* dst msb */
  172.         case 0x07a: return READ_WORD(&loopback[0xe]); /* src lsb */
  173.  
  174.         case 0x37c: return READ_WORD(&loopback[0x10]); /* src msb */
  175.         case 0x250: return READ_WORD(&loopback[0x12]);
  176.         case 0x04e: return READ_WORD(&loopback[0x14]);
  177.         case 0x5ba: return READ_WORD(&loopback[0x16]);
  178.         case 0x5f4: return READ_WORD(&loopback[0x18]); /* length */
  179.  
  180.         case 0x38c: return READ_WORD(&loopback[0x1a]); /* src msb */
  181.         case 0x02c: return READ_WORD(&loopback[0x1c]);
  182.         case 0x1e6: return READ_WORD(&loopback[0x1e]);
  183.         case 0x3e4: return READ_WORD(&loopback[0x20]);
  184.         case 0x174: return READ_WORD(&loopback[0x22]); /* length */
  185.  
  186.         /* Player 1 & 2 controls, read in IRQ then written *back* to protection device */
  187.         case 0x50: /* written to 9e byte */
  188.             return readinputport(0);
  189.         case 0x6f8: /* written to 76 byte */
  190.             return readinputport(1);
  191.         /* Controls are *really* read here! */
  192.         case 0x6fa:
  193.             return (READ_WORD(&loopback[0x9e])&0xff00) | ((READ_WORD(&loopback[0x76])>>8)&0xff);
  194.         /* These two go to the low bytes of 9e and 76.. */
  195.         case 0xc6: return 0;
  196.         case 0x7bc: return 0;
  197.         case 0x5c: /* After coin insert, high 0x8000 bit set starts game */
  198.             return READ_WORD(&loopback[0x76]);
  199.         case 0x3a6: /* Top byte OR'd with above, masked to 7 */
  200.             return READ_WORD(&loopback[0x9e]);
  201.  
  202. //        case 0xac: /* Dip switches */
  203.  
  204.         case 0xc2: /* Dip switches */
  205.             return (readinputport(3) + (readinputport(4) << 8));
  206.         case 0x5d4: /* The state of the dips _last_ frame */
  207.             return READ_WORD(&loopback[0x34]);
  208.  
  209.         case 0x76a: /* Coins */
  210.             return readinputport(2);
  211.  
  212.  
  213.  
  214. case 0x156: /* Interrupt regulate */
  215.  
  216. logerror("Int stop %04x\n",READ_WORD(&loopback[0x1a]));
  217.  
  218. cpu_spinuntil_int();
  219. //return readinputport(2);
  220.  
  221.     /* 4058 or 4056? */
  222.     return READ_WORD(&loopback[0x36])>>8;
  223.  
  224.  
  225.  
  226.  
  227. #if 0
  228.  
  229. // 5d4 == 80 when coin is inserted
  230.  
  231. // 284 == LOOKUP TABLE IMPROTANT (0 4 8 etc
  232. case 0x284: return 0;
  233.  
  234.  
  235.  
  236. case 0x2f6: /* btst 2, jsr 11a if set */
  237. if (READ_WORD(&loopback[0x40])) return 0xffff;
  238. return 0;//READ_WORD(&loopback[0x40]);//0;
  239.  
  240.  
  241. //case 0x5d4:
  242. //case 0xc2: return READ_WORD(&loopback[0x40]);//0; /* Screen flip related?! */
  243.  
  244.  
  245.  
  246.  
  247. //case 0x33e:
  248. //case 0x6c4:
  249. //    case 0x6f8: /* Player 1 & 2 input ports */
  250.  
  251.  
  252. // return value 36 is important
  253.  
  254.  
  255. /*
  256.  
  257. 6006 written to 0x40 at end of japan screen
  258.  
  259.  
  260. */
  261.  
  262.  
  263.  
  264. //case 0xc2:
  265. //case 0x5c: /* 9cde */
  266. //case 0x5d4:
  267. //return READ_WORD(&loopback[0x40]);//0;
  268.  
  269. //case 0x6fa:
  270.  
  271.  
  272.  
  273.  
  274.  
  275. /* in game prot */
  276. case 0x102: return READ_WORD(&loopback[0xa0]);
  277. case 0x15a: return READ_WORD(&loopback[0xa2]);
  278. case 0x566: return READ_WORD(&loopback[0xa4]);
  279. case 0xd2: return READ_WORD(&loopback[0xa6]);
  280. case 0x4a6: return READ_WORD(&loopback[0xa8]);
  281. case 0x3dc: return READ_WORD(&loopback[0xb0]);
  282. case 0x2a0: return READ_WORD(&loopback[0xb2]);
  283. //case 0x392: return READ_WORD(&loopback[0xa0]);
  284.  
  285.  
  286.         case 0x3b2: return READ_WORD(&loopback[0xd0]);
  287.  
  288. /* Enemy power related HIGH WORD*/
  289.         case 0x440: return READ_WORD(&loopback[0xd2]);/* Enemy power related LOW WORD*/
  290.             return 0;
  291.  
  292. //case 0x6fa:
  293. //return rand()%0xffff;
  294.  
  295. //case 0x5d4: /* Top byte:  Player 1?  lsl.4 then mask 3 for fire buttons? */
  296. //case 0x5d4:
  297.  
  298.         return 0xffff;//(readinputport(0) + (readinputport(1) << 8));
  299. #endif
  300.     }
  301.  
  302. //    logerror("Protection PC %06x: warning - read unmapped memory address %04x\n",cpu_get_pc(),offset);
  303.     return 0;
  304. }
  305.  
  306. #if 0
  307. static WRITE_HANDLER( log_m_w )
  308. {
  309.     logerror("INTERRUPT %06x: warning - write address %04x\n",cpu_get_pc(),offset);
  310.  
  311. }
  312. #endif
  313.  
  314. /**********************************************************************************/
  315.  
  316. static struct MemoryReadAddress cninja_readmem[] =
  317. {
  318.     { 0x000000, 0x0bffff, MRA_ROM },
  319.     { 0x144000, 0x144fff, cninja_pf1_data_r },
  320.     { 0x15c000, 0x15c7ff, cninja_pf3_rowscroll_r },
  321.     { 0x184000, 0x187fff, MRA_BANK1 },
  322.     { 0x190004, 0x190005, MRA_NOP }, /* Seemingly unused */
  323.     { 0x19c000, 0x19dfff, paletteram_word_r },
  324.     { 0x1a4000, 0x1a47ff, MRA_BANK2 }, /* Sprites */
  325.     { 0x1bc000, 0x1bcfff, cninja_prot_r }, /* Protection device */
  326.     { -1 }  /* end of table */
  327. };
  328.  
  329. static struct MemoryWriteAddress cninja_writemem[] =
  330. {
  331.     { 0x000000, 0x0bffff, MWA_ROM },
  332.  
  333.     { 0x140000, 0x14000f, cninja_control_1_w },
  334.     { 0x144000, 0x144fff, cninja_pf1_data_w, &cninja_pf1_data },
  335.     { 0x146000, 0x146fff, cninja_pf4_data_w, &cninja_pf4_data },
  336.     { 0x14c000, 0x14c7ff, cninja_pf1_rowscroll_w, &cninja_pf1_rowscroll },
  337.     { 0x14e000, 0x14e7ff, cninja_pf4_rowscroll_w, &cninja_pf4_rowscroll },
  338.  
  339.     { 0x150000, 0x15000f, cninja_control_0_w },
  340.     { 0x154000, 0x154fff, cninja_pf3_data_w, &cninja_pf3_data },
  341.     { 0x156000, 0x156fff, cninja_pf2_data_w, &cninja_pf2_data },
  342.     { 0x15c000, 0x15c7ff, cninja_pf3_rowscroll_w, &cninja_pf3_rowscroll },
  343.     { 0x15e000, 0x15e7ff, cninja_pf2_rowscroll_w, &cninja_pf2_rowscroll },
  344.  
  345.     { 0x184000, 0x187fff, MWA_BANK1, &cninja_ram }, /* Main ram */
  346.     { 0x190000, 0x190007, MWA_NOP }, /* IRQ Ack + DMA flags? */
  347.     { 0x19c000, 0x19dfff, cninja_palette_24bit_w, &paletteram },
  348.     { 0x1a4000, 0x1a47ff, MWA_BANK2, &spriteram, &spriteram_size },
  349.     { 0x1b4000, 0x1b4001, buffer_spriteram_w }, /* DMA flag */
  350.     { 0x1bc000, 0x1bc0ff, cninja_loopback_w }, /* Protection writes */
  351.     { 0x308000, 0x308fff, MWA_NOP }, /* Bootleg only */
  352.     { -1 }  /* end of table */
  353. };
  354.  
  355. static struct MemoryReadAddress edrandy_readmem[] =
  356. {
  357.     { 0x000000, 0x0fffff, MRA_ROM },
  358.     { 0x144000, 0x144fff, cninja_pf1_data_r },
  359.     { 0x15c000, 0x15c7ff, cninja_pf3_rowscroll_r },
  360.     { 0x188000, 0x189fff, paletteram_word_r },
  361.     { 0x194000, 0x197fff, MRA_BANK1 },
  362.     { 0x198000, 0x198fff, edrandy_prot_r }, /* Protection device */
  363.     { 0x1bc000, 0x1bc7ff, MRA_BANK2 }, /* Sprites */
  364.     { -1 }  /* end of table */
  365. };
  366.  
  367. static struct MemoryWriteAddress edrandy_writemem[] =
  368. {
  369.     { 0x000000, 0x0fffff, MWA_ROM },
  370.  
  371.     { 0x140000, 0x14000f, cninja_control_1_w },
  372.     { 0x144000, 0x144fff, cninja_pf1_data_w, &cninja_pf1_data },
  373.     { 0x146000, 0x146fff, cninja_pf4_data_w, &cninja_pf4_data },
  374.     { 0x14c000, 0x14c7ff, cninja_pf1_rowscroll_w, &cninja_pf1_rowscroll },
  375.     { 0x14e000, 0x14e7ff, cninja_pf4_rowscroll_w, &cninja_pf4_rowscroll },
  376.  
  377.     { 0x150000, 0x15000f, cninja_control_0_w },
  378.     { 0x154000, 0x154fff, cninja_pf3_data_w, &cninja_pf3_data },
  379.     { 0x156000, 0x156fff, cninja_pf2_data_w, &cninja_pf2_data },
  380.     { 0x15c000, 0x15c7ff, cninja_pf3_rowscroll_w, &cninja_pf3_rowscroll },
  381.     { 0x15e000, 0x15e7ff, cninja_pf2_rowscroll_w, &cninja_pf2_rowscroll },
  382.  
  383.     { 0x188000, 0x189fff, cninja_palette_24bit_w, &paletteram },
  384.     { 0x194000, 0x197fff, MWA_BANK1, &cninja_ram }, /* Main ram */
  385.     { 0x198064, 0x198065, cninja_sound_w }, /* Soundlatch is amongst protection */
  386.     { 0x198000, 0x1980ff, cninja_loopback_w }, /* Protection writes */
  387.     { 0x1a4000, 0x1a4007, MWA_NOP }, /* IRQ Ack + DMA flags? */
  388.     { 0x1ac000, 0x1ac001, buffer_spriteram_w }, /* DMA flag */
  389.     { 0x1bc000, 0x1bc7ff, MWA_BANK2, &spriteram, &spriteram_size },
  390.     { -1 }  /* end of table */
  391. };
  392.  
  393. /******************************************************************************/
  394.  
  395. static WRITE_HANDLER( YM2151_w )
  396. {
  397.     switch (offset) {
  398.     case 0:
  399.         YM2151_register_port_0_w(0,data);
  400.         break;
  401.     case 1:
  402.         YM2151_data_port_0_w(0,data);
  403.         break;
  404.     }
  405. }
  406.  
  407. static WRITE_HANDLER( YM2203_w )
  408. {
  409.     switch (offset) {
  410.     case 0:
  411.         YM2203_control_port_0_w(0,data);
  412.         break;
  413.     case 1:
  414.         YM2203_write_port_0_w(0,data);
  415.         break;
  416.     }
  417. }
  418.  
  419. static struct MemoryReadAddress sound_readmem[] =
  420. {
  421.     { 0x000000, 0x00ffff, MRA_ROM },
  422.     { 0x100000, 0x100001, YM2203_status_port_0_r },
  423.     { 0x110000, 0x110001, YM2151_status_port_0_r },
  424.     { 0x120000, 0x120001, OKIM6295_status_0_r },
  425.     { 0x130000, 0x130001, OKIM6295_status_1_r },
  426.     { 0x140000, 0x140001, soundlatch_r },
  427.     { 0x1f0000, 0x1f1fff, MRA_BANK8 },
  428.     { -1 }  /* end of table */
  429. };
  430.  
  431. static struct MemoryWriteAddress sound_writemem[] =
  432. {
  433.     { 0x000000, 0x00ffff, MWA_ROM },
  434.     { 0x100000, 0x100001, YM2203_w },
  435.     { 0x110000, 0x110001, YM2151_w },
  436.     { 0x120000, 0x120001, OKIM6295_data_0_w },
  437.     { 0x130000, 0x130001, OKIM6295_data_1_w },
  438.     { 0x1f0000, 0x1f1fff, MWA_BANK8 },
  439.     { 0x1fec00, 0x1fec01, H6280_timer_w },
  440.     { 0x1ff402, 0x1ff403, H6280_irq_status_w },
  441.     { -1 }  /* end of table */
  442. };
  443.  
  444. static struct MemoryReadAddress stoneage_s_readmem[] =
  445. {
  446.     { 0x0000, 0x7fff, MRA_ROM },
  447.     { 0x8000, 0x87ff, MRA_RAM },
  448.     { 0x8801, 0x8801, YM2151_status_port_0_r },
  449.     { 0xa000, 0xa000, soundlatch_r },
  450.     { 0x9800, 0x9800, OKIM6295_status_0_r },
  451.     { -1 }  /* end of table */
  452. };
  453.  
  454. static struct MemoryWriteAddress stoneage_s_writemem[] =
  455. {
  456.     { 0x0000, 0x7fff, MWA_ROM },
  457.     { 0x8000, 0x87ff, MWA_RAM },
  458.     { 0x8800, 0x8800, YM2151_register_port_0_w },
  459.     { 0x8801, 0x8801, YM2151_data_port_0_w },
  460.     { 0x9800, 0x9800, OKIM6295_data_0_w },
  461.     { -1 }  /* end of table */
  462. };
  463.  
  464. /**********************************************************************************/
  465.  
  466. #define PORTS_COINS \
  467.     PORT_START \
  468.     PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_JOYSTICK_UP    | IPF_8WAY ) \
  469.     PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_JOYSTICK_DOWN  | IPF_8WAY ) \
  470.     PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT  | IPF_8WAY ) \
  471.     PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT | IPF_8WAY ) \
  472.     PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_BUTTON1 ) \
  473.     PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_BUTTON2 ) \
  474.     PORT_BIT( 0x40, IP_ACTIVE_LOW, IPT_UNUSED ) \
  475.     PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_START1 ) \
  476.     PORT_START \
  477.     PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_JOYSTICK_UP    | IPF_8WAY | IPF_PLAYER2 ) \
  478.     PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_JOYSTICK_DOWN  | IPF_8WAY | IPF_PLAYER2 ) \
  479.     PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_JOYSTICK_LEFT  | IPF_8WAY | IPF_PLAYER2 ) \
  480.     PORT_BIT( 0x08, IP_ACTIVE_LOW, IPT_JOYSTICK_RIGHT | IPF_8WAY | IPF_PLAYER2 ) \
  481.     PORT_BIT( 0x10, IP_ACTIVE_LOW, IPT_BUTTON1 | IPF_PLAYER2 ) \
  482.     PORT_BIT( 0x20, IP_ACTIVE_LOW, IPT_BUTTON2 | IPF_PLAYER2 ) \
  483.     PORT_BIT( 0x40, IP_ACTIVE_LOW, IPT_UNUSED ) \
  484.     PORT_BIT( 0x80, IP_ACTIVE_LOW, IPT_START2 ) \
  485.     PORT_START \
  486.     PORT_BIT( 0x01, IP_ACTIVE_LOW, IPT_COIN1 ) \
  487.     PORT_BIT( 0x02, IP_ACTIVE_LOW, IPT_COIN2 ) \
  488.     PORT_BIT( 0x04, IP_ACTIVE_LOW, IPT_COIN3 ) \
  489.     PORT_BIT( 0x08, IP_ACTIVE_HIGH, IPT_VBLANK ) \
  490.     PORT_BIT( 0xf0, IP_ACTIVE_LOW, IPT_UNKNOWN )
  491.  
  492. INPUT_PORTS_START( cninja )
  493.  
  494.     PORTS_COINS
  495.  
  496.     PORT_START    /* Dip switch bank 1 */
  497.     PORT_DIPNAME( 0x07, 0x07, DEF_STR( Coin_A ) )
  498.     PORT_DIPSETTING(    0x00, DEF_STR( 3C_1C ) )
  499.     PORT_DIPSETTING(    0x01, DEF_STR( 2C_1C ) )
  500.     PORT_DIPSETTING(    0x07, DEF_STR( 1C_1C ) )
  501.     PORT_DIPSETTING(    0x06, DEF_STR( 1C_2C ) )
  502.     PORT_DIPSETTING(    0x05, DEF_STR( 1C_3C ) )
  503.     PORT_DIPSETTING(    0x04, DEF_STR( 1C_4C ) )
  504.     PORT_DIPSETTING(    0x03, DEF_STR( 1C_5C ) )
  505.     PORT_DIPSETTING(    0x02, DEF_STR( 1C_6C ) )
  506.     PORT_DIPNAME( 0x38, 0x38, DEF_STR( Coin_B ) )
  507.     PORT_DIPSETTING(    0x00, DEF_STR( 3C_1C ) )
  508.     PORT_DIPSETTING(    0x08, DEF_STR( 2C_1C ) )
  509.     PORT_DIPSETTING(    0x38, DEF_STR( 1C_1C ) )
  510.     PORT_DIPSETTING(    0x30, DEF_STR( 1C_2C ) )
  511.     PORT_DIPSETTING(    0x28, DEF_STR( 1C_3C ) )
  512.     PORT_DIPSETTING(    0x20, DEF_STR( 1C_4C ) )
  513.     PORT_DIPSETTING(    0x18, DEF_STR( 1C_5C ) )
  514.     PORT_DIPSETTING(    0x10, DEF_STR( 1C_6C ) )
  515.     PORT_DIPNAME( 0x40, 0x40, DEF_STR( Flip_Screen ) )
  516.     PORT_DIPSETTING(    0x40, DEF_STR( Off ) )
  517.     PORT_DIPSETTING(    0x00, DEF_STR( On ) )
  518.     PORT_DIPNAME( 0x80, 0x80, DEF_STR( Unknown ) )
  519.     PORT_DIPSETTING(    0x80, DEF_STR( Off ) )
  520.     PORT_DIPSETTING(    0x00, DEF_STR( On ) )
  521.  
  522.     PORT_START    /* Dip switch bank 2 */
  523.     PORT_DIPNAME( 0x03, 0x03, DEF_STR( Lives ) )
  524.     PORT_DIPSETTING(    0x01, "1" )
  525.     PORT_DIPSETTING(    0x00, "2" )
  526.     PORT_DIPSETTING(    0x03, "3" )
  527.     PORT_DIPSETTING(    0x02, "4" )
  528.     PORT_DIPNAME( 0x0c, 0x0c, DEF_STR( Difficulty ) )
  529.     PORT_DIPSETTING(    0x08, "Easy" )
  530.     PORT_DIPSETTING(    0x0c, "Normal" )
  531.     PORT_DIPSETTING(    0x04, "Hard" )
  532.     PORT_DIPSETTING(    0x00, "Hardest" )
  533.     PORT_DIPNAME( 0x10, 0x10, DEF_STR( Unknown ) )
  534.     PORT_DIPSETTING(    0x10, DEF_STR( Off ) )
  535.     PORT_DIPSETTING(    0x00, DEF_STR( On ) )
  536.     PORT_DIPNAME( 0x20, 0x20, DEF_STR( Unknown ) )
  537.     PORT_DIPSETTING(    0x20, DEF_STR( Off ) )
  538.     PORT_DIPSETTING(    0x00, DEF_STR( On ) )
  539.     PORT_DIPNAME( 0x40, 0x40, DEF_STR( Unknown ) )
  540.     PORT_DIPSETTING(    0x40, DEF_STR( Off ) )
  541.     PORT_DIPSETTING(    0x00, DEF_STR( On ) )
  542.     PORT_DIPNAME( 0x80, 0x80, DEF_STR( Demo_Sounds ) )
  543.     PORT_DIPSETTING(    0x80, DEF_STR( Off ) )
  544.     PORT_DIPSETTING(    0x00, DEF_STR( On ) )
  545. INPUT_PORTS_END
  546.  
  547. INPUT_PORTS_START( cninjau )
  548.  
  549.     PORTS_COINS
  550.  
  551.     PORT_START    /* Dip switch bank 1 */
  552.     PORT_DIPNAME( 0x07, 0x07, DEF_STR( Coin_A ) )
  553.     PORT_DIPSETTING(    0x00, DEF_STR( 3C_1C ) )
  554.     PORT_DIPSETTING(    0x01, DEF_STR( 2C_1C ) )
  555.     PORT_DIPSETTING(    0x07, DEF_STR( 1C_1C ) )
  556.     PORT_DIPSETTING(    0x06, DEF_STR( 1C_2C ) )
  557.     PORT_DIPSETTING(    0x05, DEF_STR( 1C_3C ) )
  558.     PORT_DIPSETTING(    0x04, DEF_STR( 1C_4C ) )
  559.     PORT_DIPSETTING(    0x03, DEF_STR( 1C_5C ) )
  560.     PORT_DIPSETTING(    0x02, DEF_STR( 1C_6C ) )
  561.     PORT_DIPNAME( 0x38, 0x38, DEF_STR( Coin_B ) )
  562.     PORT_DIPSETTING(    0x00, DEF_STR( 3C_1C ) )
  563.     PORT_DIPSETTING(    0x08, DEF_STR( 2C_1C ) )
  564.     PORT_DIPSETTING(    0x38, DEF_STR( 1C_1C ) )
  565.     PORT_DIPSETTING(    0x30, DEF_STR( 1C_2C ) )
  566.     PORT_DIPSETTING(    0x28, DEF_STR( 1C_3C ) )
  567.     PORT_DIPSETTING(    0x20, DEF_STR( 1C_4C ) )
  568.     PORT_DIPSETTING(    0x18, DEF_STR( 1C_5C ) )
  569.     PORT_DIPSETTING(    0x10, DEF_STR( 1C_6C ) )
  570.     PORT_DIPNAME( 0x40, 0x40, DEF_STR( Flip_Screen ) )
  571.     PORT_DIPSETTING(    0x40, DEF_STR( Off ) )
  572.     PORT_DIPSETTING(    0x00, DEF_STR( On ) )
  573.     PORT_DIPNAME( 0x80, 0x80, "Credit(s) to Start" )
  574.     PORT_DIPSETTING(    0x80, "1" )
  575.     PORT_DIPSETTING(    0x00, "2" )
  576. /* Also, if Coin A and B are on 1/1, 0x00 gives 2 to start, 1 to continue */
  577.  
  578.     PORT_START    /* Dip switch bank 2 */
  579.     PORT_DIPNAME( 0x03, 0x03, DEF_STR( Lives ) )
  580.     PORT_DIPSETTING(    0x01, "1" )
  581.     PORT_DIPSETTING(    0x00, "2" )
  582.     PORT_DIPSETTING(    0x03, "3" )
  583.     PORT_DIPSETTING(    0x02, "4" )
  584.     PORT_DIPNAME( 0x0c, 0x0c, DEF_STR( Difficulty ) )
  585.     PORT_DIPSETTING(    0x08, "Easy" )
  586.     PORT_DIPSETTING(    0x0c, "Normal" )
  587.     PORT_DIPSETTING(    0x04, "Hard" )
  588.     PORT_DIPSETTING(    0x00, "Hardest" )
  589.     PORT_DIPNAME( 0x10, 0x10, DEF_STR( Unknown ) )
  590.     PORT_DIPSETTING(    0x00, DEF_STR( Off ) )
  591.     PORT_DIPSETTING(    0x10, DEF_STR( On ) )
  592.     PORT_DIPNAME( 0x20, 0x20, DEF_STR( Unused ) )
  593.     PORT_DIPSETTING(    0x20, DEF_STR( Off ) )
  594.     PORT_DIPSETTING(    0x00, DEF_STR( On ) )
  595.     PORT_DIPNAME( 0x40, 0x40, DEF_STR( Unused ) )
  596.     PORT_DIPSETTING(    0x40, DEF_STR( Off ) )
  597.     PORT_DIPSETTING(    0x00, DEF_STR( On ) )
  598.     PORT_DIPNAME( 0x80, 0x80, DEF_STR( Demo_Sounds ) )
  599.     PORT_DIPSETTING(    0x80, DEF_STR( Off ) )
  600.     PORT_DIPSETTING(    0x00, DEF_STR( On ) )
  601. INPUT_PORTS_END
  602.  
  603. /**********************************************************************************/
  604.  
  605. static struct GfxLayout charlayout =
  606. {
  607.     8,8,    /* 8*8 chars */
  608.     4096,
  609.     4,        /* 4 bits per pixel  */
  610.     { 0x08000*8, 0x18000*8, 0x00000*8, 0x10000*8 },
  611.     { 0, 1, 2, 3, 4, 5, 6, 7 },
  612.     { 0*8, 1*8, 2*8, 3*8, 4*8, 5*8, 6*8, 7*8 },
  613.     8*8    /* every char takes 8 consecutive bytes */
  614. };
  615.  
  616. static struct GfxLayout spritelayout =
  617. {
  618.     16,16,
  619.     0x4000,  /* A lotta sprites.. */
  620.     4,
  621.     { 8, 0, 0x100000*8+8, 0x100000*8 },
  622.     { 32*8+0, 32*8+1, 32*8+2, 32*8+3, 32*8+4, 32*8+5, 32*8+6, 32*8+7,
  623.         0, 1, 2, 3, 4, 5, 6, 7 },
  624.     { 0*16, 1*16, 2*16, 3*16, 4*16, 5*16, 6*16, 7*16,
  625.             8*16, 9*16, 10*16, 11*16, 12*16, 13*16, 14*16, 15*16 },
  626.     64*8
  627. };
  628.  
  629. static struct GfxLayout spritelayout2 =
  630. {
  631.     16,16,
  632.     0xa000,  /* A lotta sprites.. */
  633.     4,
  634.     { 8, 0, 0x280000*8+8, 0x280000*8 },
  635.     { 32*8+0, 32*8+1, 32*8+2, 32*8+3, 32*8+4, 32*8+5, 32*8+6, 32*8+7,
  636.         0, 1, 2, 3, 4, 5, 6, 7 },
  637.     { 0*16, 1*16, 2*16, 3*16, 4*16, 5*16, 6*16, 7*16,
  638.             8*16, 9*16, 10*16, 11*16, 12*16, 13*16, 14*16, 15*16 },
  639.     64*8
  640. };
  641.  
  642. static struct GfxLayout tilelayout =
  643. {
  644.     16,16,
  645.     4096,
  646.     4,
  647.     { 0x40000*8+8, 0x40000*8, 8, 0,  },
  648.     { 32*8+0, 32*8+1, 32*8+2, 32*8+3, 32*8+4, 32*8+5, 32*8+6, 32*8+7,
  649.         0, 1, 2, 3, 4, 5, 6, 7 },
  650.     { 0*16, 1*16, 2*16, 3*16, 4*16, 5*16, 6*16, 7*16,
  651.             8*16, 9*16, 10*16, 11*16, 12*16, 13*16, 14*16, 15*16 },
  652.     64*8
  653. };
  654.  
  655. /* Areas 1536-2048 & 1024-1280 seem to be always empty */
  656. static struct GfxDecodeInfo gfxdecodeinfo[] =
  657. {
  658.     { REGION_GFX1, 0, &charlayout,    0, 16 },    /* Characters 8x8 */
  659.     { REGION_GFX2, 0, &tilelayout,  512, 64 },    /* Tiles 16x16 (BASE 1280) */
  660.     { REGION_GFX3, 0, &tilelayout,  512, 64 },    /* Tiles 16x16 */
  661.     { REGION_GFX4, 0, &tilelayout,  256, 16 },    /* Tiles 16x16 */
  662.     { REGION_GFX5, 0, &spritelayout,768, 16 },    /* Sprites 16x16 */
  663.     { -1 } /* end of array */
  664. };
  665.  
  666. static struct GfxDecodeInfo gfxdecodeinfo2[] =
  667. {
  668.     { REGION_GFX1, 0, &charlayout,     0, 16 },    /* Characters 8x8 */
  669.     { REGION_GFX2, 0, &tilelayout,   512, 64 },    /* Tiles 16x16 (BASE 1280) */
  670.     { REGION_GFX3, 0, &tilelayout,   512, 64 },    /* Tiles 16x16 */
  671.     { REGION_GFX4, 0, &tilelayout,   256, 16 },    /* Tiles 16x16 */
  672.     { REGION_GFX5, 0, &spritelayout2,768, 16 },    /* Sprites 16x16 */
  673.     { -1 } /* end of array */
  674. };
  675.  
  676. /**********************************************************************************/
  677.  
  678. static struct YM2203interface ym2203_interface =
  679. {
  680.     1,
  681.     32220000/8,    /* Accurate, audio section crystal is 32.220 MHz */
  682.     { YM2203_VOL(40,40) },
  683.     { 0 },
  684.     { 0 },
  685.     { 0 },
  686.     { 0 }
  687. };
  688.  
  689. static void sound_irq(int state)
  690. {
  691.     cpu_set_irq_line(1,1,state); /* IRQ 2 */
  692. }
  693.  
  694. static void sound_irq2(int state)
  695. {
  696.     cpu_set_irq_line(1,0,state);
  697. }
  698.  
  699. static WRITE_HANDLER( sound_bankswitch_w )
  700. {
  701.     /* the second OKIM6295 ROM is bank switched */
  702.     OKIM6295_set_bank_base(1, ALL_VOICES, (data & 1) * 0x40000);
  703. }
  704.  
  705. static struct YM2151interface ym2151_interface =
  706. {
  707.     1,
  708.     32220000/9, /* Accurate, audio section crystal is 32.220 MHz */
  709.     { YM3012_VOL(45,MIXER_PAN_LEFT,45,MIXER_PAN_RIGHT) },
  710.     { sound_irq },
  711.     { sound_bankswitch_w }
  712. };
  713.  
  714. static struct YM2151interface ym2151_interface2 =
  715. {
  716.     1,
  717.     3579545,    /* 3.579545 Mhz (?) */
  718.     { YM3012_VOL(50,MIXER_PAN_CENTER,50,MIXER_PAN_CENTER) },
  719.     { sound_irq2 }
  720. };
  721.  
  722. static struct OKIM6295interface okim6295_interface =
  723. {
  724.     2,              /* 2 chips */
  725.     { 7757, 15514 },/* Frequency */
  726.     { REGION_SOUND1, REGION_SOUND2 },       /* memory regions 3 & 4 */
  727.     { 50, 25 }        /* Note!  Keep chip 1 (voices) louder than chip 2 */
  728. };
  729.  
  730. /**********************************************************************************/
  731.  
  732. static struct MachineDriver machine_driver_cninja =
  733. {
  734.     /* basic machine hardware */
  735.     {
  736.         {
  737.             CPU_M68000,
  738.             12000000,
  739.             cninja_readmem,cninja_writemem,0,0,
  740.             m68_level5_irq,1
  741.         },
  742.         {
  743.             CPU_H6280 | CPU_AUDIO_CPU,
  744.             32220000/8,    /* Accurate */
  745.             sound_readmem,sound_writemem,0,0,
  746.             ignore_interrupt,0
  747.         }
  748.     },
  749.     58, 529,
  750.     1,    /* 1 CPU slice per frame - interleaving is forced when a sound command is written */
  751.     0,
  752.  
  753.     /* video hardware */
  754.     32*8, 32*8, { 0*8, 32*8-1, 1*8, 31*8-1 },
  755.  
  756.     gfxdecodeinfo,
  757.     2048, 2048,
  758.     0,
  759.  
  760.     VIDEO_TYPE_RASTER | VIDEO_MODIFIES_PALETTE | VIDEO_UPDATE_BEFORE_VBLANK | VIDEO_BUFFERS_SPRITERAM,
  761.     0,
  762.     cninja_vh_start,
  763.     0,
  764.     cninja_vh_screenrefresh,
  765.  
  766.     /* sound hardware */
  767.     0,0,0,0, /* Mono */
  768.       {
  769.         {
  770.             SOUND_YM2203,
  771.             &ym2203_interface
  772.         },
  773.         {
  774.             SOUND_YM2151,
  775.             &ym2151_interface
  776.         },
  777.         {
  778.             SOUND_OKIM6295,
  779.             &okim6295_interface
  780.         }
  781.     }
  782. };
  783.  
  784. static struct MachineDriver machine_driver_stoneage =
  785. {
  786.     /* basic machine hardware */
  787.     {
  788.         {
  789.             CPU_M68000,
  790.             12000000,
  791.             cninja_readmem,cninja_writemem,0,0,
  792.             m68_level5_irq,1
  793.         },
  794.         {
  795.             CPU_Z80 | CPU_AUDIO_CPU,
  796.             3579545,
  797.             stoneage_s_readmem,stoneage_s_writemem,0,0,
  798.             ignore_interrupt,0
  799.         }
  800.     },
  801.     58, 529,
  802.     1,    /* 1 CPU slice per frame - interleaving is forced when a sound command is written */
  803.     0,
  804.  
  805.     /* video hardware */
  806.     32*8, 32*8, { 0*8, 32*8-1, 1*8, 31*8-1 },
  807.  
  808.     gfxdecodeinfo,
  809.     2048, 2048,
  810.     0,
  811.  
  812.     VIDEO_TYPE_RASTER | VIDEO_MODIFIES_PALETTE | VIDEO_UPDATE_BEFORE_VBLANK | VIDEO_BUFFERS_SPRITERAM,
  813.     0,
  814.     stoneage_vh_start,
  815.     0,
  816.     cninja_vh_screenrefresh,
  817.  
  818.     /* sound hardware */
  819.     0,0,0,0, /* Mono */
  820.     {
  821.         {
  822.             SOUND_YM2151,
  823.             &ym2151_interface2
  824.         },
  825.         {
  826.             SOUND_OKIM6295,
  827.             &okim6295_interface
  828.         }
  829.     }
  830. };
  831.  
  832. static struct MachineDriver machine_driver_edrandy =
  833. {
  834.     /* basic machine hardware */
  835.     {
  836.         {
  837.             CPU_M68000,
  838.             12000000,
  839.             edrandy_readmem,edrandy_writemem,0,0,
  840.             m68_level5_irq,1
  841.         },
  842.         {
  843.             CPU_H6280 | CPU_AUDIO_CPU,
  844.             32220000/8,    /* Accurate */
  845.             sound_readmem,sound_writemem,0,0,
  846.             ignore_interrupt,0
  847.         }
  848.     },
  849.     58, 529,
  850.     1,    /* 1 CPU slice per frame - interleaving is forced when a sound command is written */
  851.     0,
  852.  
  853.     /* video hardware */
  854.     32*8, 32*8, { 0*8, 32*8-1, 1*8, 31*8-1 },
  855.  
  856.     gfxdecodeinfo2,
  857.     2048, 2048,
  858.     0,
  859.  
  860.     VIDEO_TYPE_RASTER | VIDEO_MODIFIES_PALETTE | VIDEO_UPDATE_BEFORE_VBLANK | VIDEO_BUFFERS_SPRITERAM,
  861.     0,
  862.     edrandy_vh_start,
  863.     0,
  864.     cninja_vh_screenrefresh,
  865.  
  866.     /* sound hardware */
  867.     0,0,0,0, /* Mono */
  868.       {
  869.         {
  870.             SOUND_YM2203,
  871.             &ym2203_interface
  872.         },
  873.         {
  874.             SOUND_YM2151,
  875.             &ym2151_interface
  876.         },
  877.         {
  878.             SOUND_OKIM6295,
  879.             &okim6295_interface
  880.         }
  881.     }
  882. };
  883.  
  884. /**********************************************************************************/
  885.  
  886. ROM_START( cninja )
  887.     ROM_REGION( 0xc0000, REGION_CPU1 ) /* 68000 code */
  888.     ROM_LOAD_EVEN( "gn02rev3.bin", 0x00000, 0x20000, 0x39aea12a )
  889.     ROM_LOAD_ODD ( "gn05rev2.bin", 0x00000, 0x20000, 0x0f4360ef )
  890.     ROM_LOAD_EVEN( "gn01rev2.bin", 0x40000, 0x20000, 0xf740ef7e )
  891.     ROM_LOAD_ODD ( "gn04rev2.bin", 0x40000, 0x20000, 0xc98fcb62 )
  892.     ROM_LOAD_EVEN( "gn-00.rom",    0x80000, 0x20000, 0x0b110b16 )
  893.     ROM_LOAD_ODD ( "gn-03.rom",    0x80000, 0x20000, 0x1e28e697 )
  894.  
  895.     ROM_REGION( 0x10000, REGION_CPU2 ) /* Sound CPU */
  896.     ROM_LOAD( "gl-07.rom",  0x00000,  0x10000,  0xca8bef96 )
  897.  
  898.     ROM_REGION( 0x020000, REGION_GFX1 | REGIONFLAG_DISPOSE )
  899.     ROM_LOAD( "gl-08.rom",  0x00000,  0x10000,  0x33a2b400 )    /* chars */
  900.     ROM_LOAD( "gl-09.rom",  0x10000,  0x10000,  0x5a2d4752 )
  901.  
  902.     ROM_REGION( 0x080000, REGION_GFX2 | REGIONFLAG_DISPOSE )
  903.     ROM_LOAD( "mag-00.rom", 0x000000, 0x80000,  0xa8f05d33 )    /* tiles 1 */
  904.  
  905.     ROM_REGION( 0x080000, REGION_GFX3 | REGIONFLAG_DISPOSE )
  906.     ROM_LOAD( "mag-01.rom", 0x000000, 0x80000,  0x5b399eed )    /* tiles 2 */
  907.  
  908.     ROM_REGION( 0x080000, REGION_GFX4 | REGIONFLAG_DISPOSE )
  909.     ROM_LOAD( "mag-02.rom", 0x000000, 0x80000,  0xde89c69a )    /* tiles 3 */
  910.  
  911.     ROM_REGION( 0x200000, REGION_GFX5 | REGIONFLAG_DISPOSE )
  912.     ROM_LOAD( "mag-03.rom", 0x000000, 0x80000,  0x2220eb9f )    /* sprites */
  913.     ROM_LOAD( "mag-04.rom", 0x080000, 0x80000,  0x144b94cc )
  914.     ROM_LOAD( "mag-05.rom", 0x100000, 0x80000,  0x56a53254 )
  915.     ROM_LOAD( "mag-06.rom", 0x180000, 0x80000,  0x82d44749 )
  916.  
  917.     ROM_REGION( 0x20000, REGION_SOUND1 ) /* Oki samples */
  918.     ROM_LOAD( "gl-06.rom",  0x00000,  0x20000,  0xd92e519d )
  919.  
  920.     ROM_REGION( 0x80000, REGION_SOUND2 ) /* Extra Oki samples */
  921.     ROM_LOAD( "mag-07.rom", 0x00000,  0x80000,  0x08eb5264 )    /* banked */
  922. ROM_END
  923.  
  924. ROM_START( cninja0 )
  925.     ROM_REGION( 0xc0000, REGION_CPU1 ) /* 68000 code */
  926.     ROM_LOAD_EVEN( "gn-02.rom", 0x00000, 0x20000, 0xccc59524 )
  927.     ROM_LOAD_ODD ( "gn-05.rom", 0x00000, 0x20000, 0xa002cbe4 )
  928.     ROM_LOAD_EVEN( "gn-01.rom", 0x40000, 0x20000, 0x18f0527c )
  929.     ROM_LOAD_ODD ( "gn-04.rom", 0x40000, 0x20000, 0xea4b6d53 )
  930.     ROM_LOAD_EVEN( "gn-00.rom", 0x80000, 0x20000, 0x0b110b16 )
  931.     ROM_LOAD_ODD ( "gn-03.rom", 0x80000, 0x20000, 0x1e28e697 )
  932.  
  933.     ROM_REGION( 0x10000, REGION_CPU2 ) /* Sound CPU */
  934.     ROM_LOAD( "gl-07.rom",  0x00000,  0x10000,  0xca8bef96 )
  935.  
  936.     ROM_REGION( 0x020000, REGION_GFX1 | REGIONFLAG_DISPOSE )
  937.     ROM_LOAD( "gl-08.rom",  0x00000,  0x10000,  0x33a2b400 )    /* chars */
  938.     ROM_LOAD( "gl-09.rom",  0x10000,  0x10000,  0x5a2d4752 )
  939.  
  940.     ROM_REGION( 0x080000, REGION_GFX2 | REGIONFLAG_DISPOSE )
  941.     ROM_LOAD( "mag-00.rom", 0x000000, 0x80000,  0xa8f05d33 )    /* tiles 1 */
  942.  
  943.     ROM_REGION( 0x080000, REGION_GFX3 | REGIONFLAG_DISPOSE )
  944.     ROM_LOAD( "mag-01.rom", 0x000000, 0x80000,  0x5b399eed )    /* tiles 2 */
  945.  
  946.     ROM_REGION( 0x080000, REGION_GFX4 | REGIONFLAG_DISPOSE )
  947.     ROM_LOAD( "mag-02.rom", 0x000000, 0x80000,  0xde89c69a )    /* tiles 3 */
  948.  
  949.     ROM_REGION( 0x200000, REGION_GFX5 | REGIONFLAG_DISPOSE )
  950.     ROM_LOAD( "mag-03.rom", 0x000000, 0x80000,  0x2220eb9f )    /* sprites */
  951.     ROM_LOAD( "mag-04.rom", 0x080000, 0x80000,  0x144b94cc )
  952.     ROM_LOAD( "mag-05.rom", 0x100000, 0x80000,  0x56a53254 )
  953.     ROM_LOAD( "mag-06.rom", 0x180000, 0x80000,  0x82d44749 )
  954.  
  955.     ROM_REGION( 0x20000, REGION_SOUND1 ) /* Oki samples */
  956.     ROM_LOAD( "gl-06.rom",  0x00000,  0x20000,  0xd92e519d )
  957.  
  958.     ROM_REGION( 0x80000, REGION_SOUND2 ) /* Extra Oki samples */
  959.     ROM_LOAD( "mag-07.rom", 0x00000,  0x80000,  0x08eb5264 )    /* banked */
  960. ROM_END
  961.  
  962. ROM_START( cninjau )
  963.     ROM_REGION( 0xc0000, REGION_CPU1 ) /* 68000 code */
  964.     ROM_LOAD_EVEN( "gm02-3.1k", 0x00000, 0x20000, 0xd931c3b1 )
  965.     ROM_LOAD_ODD ( "gm05-2.3k", 0x00000, 0x20000, 0x7417d3fb )
  966.     ROM_LOAD_EVEN( "gm01-2.1j", 0x40000, 0x20000, 0x72041f7e )
  967.     ROM_LOAD_ODD ( "gm04-2.3j", 0x40000, 0x20000, 0x2104d005 )
  968.     ROM_LOAD_EVEN( "gn-00.rom", 0x80000, 0x20000, 0x0b110b16 )
  969.     ROM_LOAD_ODD ( "gn-03.rom", 0x80000, 0x20000, 0x1e28e697 )
  970.  
  971.     ROM_REGION( 0x10000, REGION_CPU2 ) /* Sound CPU */
  972.     ROM_LOAD( "gl-07.rom",  0x00000,  0x10000,  0xca8bef96 )
  973.  
  974.     ROM_REGION( 0x020000, REGION_GFX1 | REGIONFLAG_DISPOSE )
  975.     ROM_LOAD( "gl-08.rom",  0x00000,  0x10000,  0x33a2b400 )    /* chars */
  976.     ROM_LOAD( "gl-09.rom",  0x10000,  0x10000,  0x5a2d4752 )
  977.  
  978.     ROM_REGION( 0x080000, REGION_GFX2 | REGIONFLAG_DISPOSE )
  979.     ROM_LOAD( "mag-00.rom", 0x000000, 0x80000,  0xa8f05d33 )    /* tiles 1 */
  980.  
  981.     ROM_REGION( 0x080000, REGION_GFX3 | REGIONFLAG_DISPOSE )
  982.     ROM_LOAD( "mag-01.rom", 0x000000, 0x80000,  0x5b399eed )    /* tiles 2 */
  983.  
  984.     ROM_REGION( 0x080000, REGION_GFX4 | REGIONFLAG_DISPOSE )
  985.     ROM_LOAD( "mag-02.rom", 0x000000, 0x80000,  0xde89c69a )    /* tiles 3 */
  986.  
  987.     ROM_REGION( 0x200000, REGION_GFX5 | REGIONFLAG_DISPOSE )
  988.     ROM_LOAD( "mag-03.rom", 0x000000, 0x80000,  0x2220eb9f )    /* sprites */
  989.     ROM_LOAD( "mag-04.rom", 0x080000, 0x80000,  0x144b94cc )
  990.     ROM_LOAD( "mag-05.rom", 0x100000, 0x80000,  0x56a53254 )
  991.     ROM_LOAD( "mag-06.rom", 0x180000, 0x80000,  0x82d44749 )
  992.  
  993.     ROM_REGION( 0x20000, REGION_SOUND1 ) /* Oki samples */
  994.     ROM_LOAD( "gl-06.rom",  0x00000,  0x20000,  0xd92e519d )
  995.  
  996.     ROM_REGION( 0x80000, REGION_SOUND2 ) /* Extra Oki samples */
  997.     ROM_LOAD( "mag-07.rom", 0x00000,  0x80000,  0x08eb5264 )    /* banked */
  998. ROM_END
  999.  
  1000. ROM_START( joemac )
  1001.     ROM_REGION( 0xc0000, REGION_CPU1 ) /* 68000 code */
  1002.     ROM_LOAD_EVEN( "gl02-2.k1", 0x00000, 0x20000,  0x80da12e2 )
  1003.     ROM_LOAD_ODD ( "gl05-2.k3", 0x00000, 0x20000,  0xfe4dbbbb )
  1004.     ROM_LOAD_EVEN( "gl01-2.j1", 0x40000, 0x20000,  0x0b245307 )
  1005.     ROM_LOAD_ODD ( "gl04-2.j3", 0x40000, 0x20000,  0x1b331f61 )
  1006.     ROM_LOAD_EVEN( "gn-00.rom", 0x80000, 0x20000,  0x0b110b16 )
  1007.     ROM_LOAD_ODD ( "gn-03.rom", 0x80000, 0x20000,  0x1e28e697 )
  1008.  
  1009.     ROM_REGION( 0x10000, REGION_CPU2 ) /* Sound CPU */
  1010.     ROM_LOAD( "gl-07.rom",  0x00000,  0x10000,  0xca8bef96 )
  1011.  
  1012.     ROM_REGION( 0x020000, REGION_GFX1 | REGIONFLAG_DISPOSE )
  1013.     ROM_LOAD( "gl-08.rom",  0x00000,  0x10000,  0x33a2b400 )    /* chars */
  1014.     ROM_LOAD( "gl-09.rom",  0x10000,  0x10000,  0x5a2d4752 )
  1015.  
  1016.     ROM_REGION( 0x080000, REGION_GFX2 | REGIONFLAG_DISPOSE )
  1017.     ROM_LOAD( "mag-00.rom", 0x000000, 0x80000,  0xa8f05d33 )    /* tiles 1 */
  1018.  
  1019.     ROM_REGION( 0x080000, REGION_GFX3 | REGIONFLAG_DISPOSE )
  1020.     ROM_LOAD( "mag-01.rom", 0x000000, 0x80000,  0x5b399eed )    /* tiles 2 */
  1021.  
  1022.     ROM_REGION( 0x080000, REGION_GFX4 | REGIONFLAG_DISPOSE )
  1023.     ROM_LOAD( "mag-02.rom", 0x000000, 0x80000,  0xde89c69a )    /* tiles 3 */
  1024.  
  1025.     ROM_REGION( 0x200000, REGION_GFX5 | REGIONFLAG_DISPOSE )
  1026.     ROM_LOAD( "mag-03.rom", 0x000000, 0x80000,  0x2220eb9f )    /* sprites */
  1027.     ROM_LOAD( "mag-04.rom", 0x080000, 0x80000,  0x144b94cc )
  1028.     ROM_LOAD( "mag-05.rom", 0x100000, 0x80000,  0x56a53254 )
  1029.     ROM_LOAD( "mag-06.rom", 0x180000, 0x80000,  0x82d44749 )
  1030.  
  1031.     ROM_REGION( 0x20000, REGION_SOUND1 ) /* Oki samples */
  1032.     ROM_LOAD( "gl-06.rom",  0x00000,  0x20000,  0xd92e519d )
  1033.  
  1034.     ROM_REGION( 0x80000, REGION_SOUND2 ) /* Extra Oki samples */
  1035.     ROM_LOAD( "mag-07.rom", 0x00000,  0x80000,  0x08eb5264 )    /* banked */
  1036. ROM_END
  1037.  
  1038. ROM_START( stoneage )
  1039.     ROM_REGION( 0xc0000, REGION_CPU1 ) /* 68000 code */
  1040.     ROM_LOAD_EVEN( "sa_1_019.bin", 0x00000, 0x20000,  0x7fb8c44f )
  1041.     ROM_LOAD_ODD ( "sa_1_033.bin", 0x00000, 0x20000,  0x961c752b )
  1042.     ROM_LOAD_EVEN( "sa_1_018.bin", 0x40000, 0x20000,  0xa4043022 )
  1043.     ROM_LOAD_ODD ( "sa_1_032.bin", 0x40000, 0x20000,  0xf52a3286 )
  1044.     ROM_LOAD_EVEN( "sa_1_017.bin", 0x80000, 0x20000,  0x08d6397a )
  1045.     ROM_LOAD_ODD ( "sa_1_031.bin", 0x80000, 0x20000,  0x103079f5 )
  1046.  
  1047.     ROM_REGION( 0x10000, REGION_CPU2 ) /* Sound CPU */
  1048.     ROM_LOAD( "sa_1_012.bin",  0x00000,  0x10000, 0x56058934 )
  1049.  
  1050.     ROM_REGION( 0x020000, REGION_GFX1 | REGIONFLAG_DISPOSE )
  1051.     ROM_LOAD( "gl-08.rom",  0x00000,  0x10000,  0x33a2b400 )    /* chars */
  1052.     ROM_LOAD( "gl-09.rom",  0x10000,  0x10000,  0x5a2d4752 )
  1053.  
  1054.     /* The bootleg graphics are stored in a different arrangement but
  1055.         seem to be the same as the original set */
  1056.  
  1057.     ROM_REGION( 0x080000, REGION_GFX2 | REGIONFLAG_DISPOSE )
  1058.     ROM_LOAD( "mag-00.rom", 0x000000, 0x80000,  0xa8f05d33 )    /* tiles 1 */
  1059.  
  1060.     ROM_REGION( 0x080000, REGION_GFX3 | REGIONFLAG_DISPOSE )
  1061.     ROM_LOAD( "mag-01.rom", 0x000000, 0x80000,  0x5b399eed )    /* tiles 2 */
  1062.  
  1063.     ROM_REGION( 0x080000, REGION_GFX4 | REGIONFLAG_DISPOSE )
  1064.     ROM_LOAD( "mag-02.rom", 0x000000, 0x80000,  0xde89c69a )    /* tiles 3 */
  1065.  
  1066.     ROM_REGION( 0x200000, REGION_GFX5 | REGIONFLAG_DISPOSE )
  1067.     ROM_LOAD( "mag-03.rom", 0x000000, 0x80000,  0x2220eb9f )    /* sprites */
  1068.     ROM_LOAD( "mag-04.rom", 0x080000, 0x80000,  0x144b94cc )
  1069.     ROM_LOAD( "mag-05.rom", 0x100000, 0x80000,  0x56a53254 )
  1070.     ROM_LOAD( "mag-06.rom", 0x180000, 0x80000,  0x82d44749 )
  1071.  
  1072.     ROM_REGION( 0x40000, REGION_SOUND1 ) /* Oki samples */
  1073.     ROM_LOAD( "sa_1_069.bin",  0x00000,  0x40000, 0x2188f3ca )
  1074.  
  1075.     /* No extra Oki samples in the bootleg */
  1076. ROM_END
  1077.  
  1078. ROM_START( edrandy )
  1079.     ROM_REGION( 0x100000, REGION_CPU1 ) /* 68000 code */
  1080.       ROM_LOAD_EVEN( "gg-00-2", 0x00000, 0x20000, 0xce1ba964 )
  1081.       ROM_LOAD_ODD ( "gg-04-2", 0x00000, 0x20000, 0x24caed19 )
  1082.     ROM_LOAD_EVEN( "gg-01-2", 0x40000, 0x20000, 0x33677b80 )
  1083.      ROM_LOAD_ODD ( "gg-05-2", 0x40000, 0x20000, 0x79a68ca6 )
  1084.     ROM_LOAD_EVEN( "ge-02",   0x80000, 0x20000, 0xc2969fbb )
  1085.     ROM_LOAD_ODD ( "ge-06",   0x80000, 0x20000, 0x5c2e6418 )
  1086.     ROM_LOAD_EVEN( "ge-03",   0xc0000, 0x20000, 0x5e7b19a8 )
  1087.     ROM_LOAD_ODD ( "ge-07",   0xc0000, 0x20000, 0x5eb819a1 )
  1088.  
  1089.     ROM_REGION( 0x10000, REGION_CPU2 )    /* Sound CPU */
  1090.     ROM_LOAD( "ge-09",    0x00000, 0x10000, 0x9f94c60b )
  1091.  
  1092.     ROM_REGION( 0x020000, REGION_GFX1 | REGIONFLAG_DISPOSE )
  1093.     ROM_LOAD( "gg-11",    0x000000, 0x10000, 0xee567448 )
  1094.       ROM_LOAD( "gg-10",    0x010000, 0x10000, 0xb96c6cbe )
  1095.  
  1096.     ROM_REGION( 0x080000, REGION_GFX2 | REGIONFLAG_DISPOSE )
  1097.     ROM_LOAD( "mad-00",   0x000000, 0x80000, 0x3735b22d ) /* tiles 1 */
  1098.  
  1099.     ROM_REGION( 0x080000, REGION_GFX3 | REGIONFLAG_DISPOSE )
  1100.     ROM_LOAD( "mad-01",   0x000000, 0x80000, 0x7bb13e1c ) /* tiles 2 */
  1101.  
  1102.     ROM_REGION( 0x080000, REGION_GFX4 | REGIONFLAG_DISPOSE )
  1103.     ROM_LOAD( "mad-02",   0x000000, 0x80000, 0x6c76face ) /* tiles 3 */
  1104.  
  1105.     ROM_REGION( 0x500000, REGION_GFX5 | REGIONFLAG_DISPOSE )
  1106.     ROM_LOAD( "mad-03",   0x000000, 0x80000, 0xc0bff892 ) /* sprites */
  1107.     ROM_LOAD( "mad-04",   0x080000, 0x80000, 0x464f3eb9 )
  1108.     ROM_LOAD( "mad-07",   0x100000, 0x80000, 0xac03466e )
  1109.     ROM_LOAD( "mad-10",   0x180000, 0x80000, 0x42da8ef0 )
  1110.     ROM_LOAD( "mad-09",   0x200000, 0x80000, 0x930f4900 )
  1111.     ROM_LOAD( "mad-05",   0x280000, 0x80000, 0x3f2ccf95 )
  1112.     ROM_LOAD( "mad-06",   0x300000, 0x80000, 0x60871f77 )
  1113.     ROM_LOAD( "mad-08",   0x380000, 0x80000, 0x1b420ec8 )
  1114.     ROM_LOAD( "mad-11",   0x400000, 0x80000, 0x03c1f982 )
  1115.     ROM_LOAD( "mad-12",   0x480000, 0x80000, 0xa0bd62b6 )
  1116.  
  1117.     ROM_REGION( 0x20000, REGION_SOUND1 )    /* ADPCM samples */
  1118.     ROM_LOAD( "ge-08",    0x00000, 0x20000, 0xdfe28c7b )
  1119.  
  1120.     ROM_REGION( 0x80000, REGION_SOUND2 ) /* Extra Oki samples */
  1121.     ROM_LOAD( "mad-13", 0x00000, 0x80000, 0x6ab28eba )    /* banked */
  1122. ROM_END
  1123.  
  1124. ROM_START( edrandyj )
  1125.     ROM_REGION( 0x100000, REGION_CPU1 ) /* 68000 code */
  1126.       ROM_LOAD_EVEN( "ge-00-2",   0x00000, 0x20000, 0xb3d2403c )
  1127.       ROM_LOAD_ODD ( "ge-04-2",   0x00000, 0x20000, 0x8a9624d6 )
  1128.     ROM_LOAD_EVEN( "ge-01-2",   0x40000, 0x20000, 0x84360123 )
  1129.      ROM_LOAD_ODD ( "ge-05-2",   0x40000, 0x20000, 0x0bf85d9d )
  1130.     ROM_LOAD_EVEN( "ge-02",     0x80000, 0x20000, 0xc2969fbb )
  1131.     ROM_LOAD_ODD ( "ge-06",     0x80000, 0x20000, 0x5c2e6418 )
  1132.     ROM_LOAD_EVEN( "ge-03",     0xc0000, 0x20000, 0x5e7b19a8 )
  1133.     ROM_LOAD_ODD ( "ge-07",     0xc0000, 0x20000, 0x5eb819a1 )
  1134.  
  1135.     ROM_REGION( 0x10000, REGION_CPU2 )    /* Sound CPU */
  1136.     ROM_LOAD( "ge-09",    0x00000, 0x10000, 0x9f94c60b )
  1137.  
  1138.     ROM_REGION( 0x020000, REGION_GFX1 | REGIONFLAG_DISPOSE )
  1139.     ROM_LOAD( "ge-10",    0x000000, 0x10000, 0x2528d795 )
  1140.       ROM_LOAD( "ge-11",    0x010000, 0x10000, 0xe34a931e )
  1141.  
  1142.     ROM_REGION( 0x080000, REGION_GFX2 | REGIONFLAG_DISPOSE )
  1143.     ROM_LOAD( "mad-00",   0x000000, 0x80000, 0x3735b22d ) /* tiles 1 */
  1144.  
  1145.     ROM_REGION( 0x080000, REGION_GFX3 | REGIONFLAG_DISPOSE )
  1146.     ROM_LOAD( "mad-01",   0x000000, 0x80000, 0x7bb13e1c ) /* tiles 2 */
  1147.  
  1148.     ROM_REGION( 0x080000, REGION_GFX4 | REGIONFLAG_DISPOSE )
  1149.     ROM_LOAD( "mad-02",   0x000000, 0x80000, 0x6c76face ) /* tiles 3 */
  1150.  
  1151.     ROM_REGION( 0x500000, REGION_GFX5 | REGIONFLAG_DISPOSE )
  1152.     ROM_LOAD( "mad-03",   0x000000, 0x80000, 0xc0bff892 ) /* sprites */
  1153.     ROM_LOAD( "mad-04",   0x080000, 0x80000, 0x464f3eb9 )
  1154.     ROM_LOAD( "mad-07",   0x100000, 0x80000, 0xac03466e )
  1155.     ROM_LOAD( "mad-10",   0x180000, 0x80000, 0x42da8ef0 )
  1156.     ROM_LOAD( "mad-09",   0x200000, 0x80000, 0x930f4900 )
  1157.     ROM_LOAD( "mad-05",   0x280000, 0x80000, 0x3f2ccf95 )
  1158.     ROM_LOAD( "mad-06",   0x300000, 0x80000, 0x60871f77 )
  1159.     ROM_LOAD( "mad-08",   0x380000, 0x80000, 0x1b420ec8 )
  1160.     ROM_LOAD( "mad-11",   0x400000, 0x80000, 0x03c1f982 )
  1161.     ROM_LOAD( "mad-12",   0x480000, 0x80000, 0xa0bd62b6 )
  1162.  
  1163.     ROM_REGION( 0x20000, REGION_SOUND1 )    /* ADPCM samples */
  1164.     ROM_LOAD( "ge-08",    0x00000, 0x20000, 0xdfe28c7b )
  1165.  
  1166.     ROM_REGION( 0x80000, REGION_SOUND2 ) /* Extra Oki samples */
  1167.     ROM_LOAD( "mad-13", 0x00000, 0x80000, 0x6ab28eba )    /* banked */
  1168. ROM_END
  1169.  
  1170. /**********************************************************************************/
  1171.  
  1172. static void cninja_patch(void)
  1173. {
  1174.     unsigned char *RAM = memory_region(REGION_CPU1);
  1175.     int i;
  1176.  
  1177.     for (i=0; i<0x80000; i+=2) {
  1178.         int aword=READ_WORD(&RAM[i]);
  1179.  
  1180.         if (aword==0x66ff || aword==0x67ff) {
  1181.             int doublecheck=READ_WORD(&RAM[i-8]);
  1182.  
  1183.             /* Cmpi + btst controlling opcodes */
  1184.             if (doublecheck==0xc39 || doublecheck==0x839) {
  1185.  
  1186.                 WRITE_WORD (&RAM[i],0x4E71);
  1187.                 WRITE_WORD (&RAM[i-2],0x4E71);
  1188.                 WRITE_WORD (&RAM[i-4],0x4E71);
  1189.                 WRITE_WORD (&RAM[i-6],0x4E71);
  1190.                 WRITE_WORD (&RAM[i-8],0x4E71);
  1191.             }
  1192.         }
  1193.     }
  1194. }
  1195.  
  1196. #if 0
  1197. static void edrandyj_patch(void)
  1198. {
  1199. //    unsigned char *RAM = memory_region(REGION_CPU1);
  1200.  
  1201. //    WRITE_WORD (&RAM[0x98cc],0x4E71);
  1202. //    WRITE_WORD (&RAM[0x98ce],0x4E71);
  1203.  
  1204. }
  1205. #endif
  1206.  
  1207. /**********************************************************************************/
  1208.  
  1209. static void init_cninja(void)
  1210. {
  1211.     install_mem_write_handler(0, 0x1bc0a8, 0x1bc0a9, cninja_sound_w);
  1212.     cninja_patch();
  1213. }
  1214.  
  1215. static void init_stoneage(void)
  1216. {
  1217.     install_mem_write_handler(0, 0x1bc0a8, 0x1bc0a9, stoneage_sound_w);
  1218. }
  1219.  
  1220. /**********************************************************************************/
  1221.  
  1222. GAME( 1991, cninja,   0,       cninja,   cninja,  cninja,   ROT0, "Data East Corporation", "Caveman Ninja (World revision 3)" )
  1223. GAME( 1991, cninja0,  cninja,  cninja,   cninja,  cninja,   ROT0, "Data East Corporation", "Caveman Ninja (World revision 0)" )
  1224. GAME( 1991, cninjau,  cninja,  cninja,   cninjau, cninja,   ROT0, "Data East Corporation", "Caveman Ninja (US)" )
  1225. GAME( 1991, joemac,   cninja,  cninja,   cninja,  cninja,   ROT0, "Data East Corporation", "Joe & Mac (Japan)" )
  1226. GAME( 1991, stoneage, cninja,  stoneage, cninja,  stoneage, ROT0, "bootleg", "Stoneage" )
  1227. GAMEX(1990, edrandy,  0,       edrandy,  cninja,  0,        ROT0, "Data East Corporation", "Edward Randy (World)", GAME_NOT_WORKING )
  1228. GAMEX(1990, edrandyj, edrandy, edrandy,  cninja,  0,        ROT0, "Data East Corporation", "Edward Randy (Japan)", GAME_NOT_WORKING )
  1229.